## Quad Digitally-Controlled (XDCP ${ }^{\text {TM }}$ ) Potentiometer

The X9252 integrates 4 digitally controlled potentiometers (XDCP) on a monolithic CMOS integrated circuit.

The digitally controlled potentiometers are implemented using 255 resistive elements in a series array. Between each pair of elements are tap points connected to wiper terminals through switches. The position of each wiper on the array is controlled by the user through the Up/Down (U/ $\overline{\mathrm{D}}$ ) or 2-wire bus interface. The wiper of each potentiometer has an associated volatile Wiper Counter Register (WCR) and four non-volatile Data Registers (DRs) that can be directly written to and read by the user. The contents of the WCR controls the position of the wiper on the resistor array through the switches. At power-up, the device recalls the contents of the default data registers DR00, DR10, DR20, DR30, to the corresponding WCR.

Each DCP can be used as a three-terminal potentiometer or as a two terminal variable resistor in a wide variety of applications including the programming of bias voltages, the implementation of ladder networks, and three resistor programmable networks.

## Features

- Quad Solid State Potentiometer
- 256 Wiper Tap Points-0.4\% Resolution
- 2-Wire Serial Interface for Write, Read, and Transfer Operations of the Potentiometer
- Up/Down Interface for Individual Potentiometers
- Wiper Resistance: $40 \Omega$ Typical
- Non-Volatile Storage of Wiper Positions
- Power On Recall. Loads Saved Wiper Position on PowerUp.
- Standby Current $<100 \mu \mathrm{~A}$ Max
- Maximum Wiper Current: 3mA
- $\mathrm{V}_{\mathrm{CC}}: 2.7 \mathrm{~V}$ to 5.5 V Operation
- $2.8 \mathrm{k} \Omega, 10 \mathrm{k} \Omega, 50 \mathrm{k} \Omega, 100 \mathrm{k} \Omega$ Version of Total Pot Resistance
- Endurance: 100,000 Data Changes per Bit per Register
- 100 yr. Data Retention
- 24 Ld SOIC, 24 Ld TSSOP
- Pb-Free Plus Anneal Available (RoHS Compliant)


## Pinout

X9252
(24 LD SOIC/TSSOP)
TOP VIEW


Ordering Information

| PART NUMBER | PART MARKING | $\mathrm{R}_{\text {TOTAL }}(\mathrm{k} \Omega$ ) | TEMP RANGE ( ${ }^{\circ} \mathrm{C}$ ) | PACKAGE |
| :---: | :---: | :---: | :---: | :---: |
| X9252YS24I-2.7 |  | 2.8 | -40 to 85 | 24 Ld SOIC (300 mil) |
| X9252YS24IZ-2.7 (Note) |  |  | -40 to 85 | 24 Ld SOIC (300 mil) (Pb-Free) |
| X9252YV24I-2.7 | X9252YV G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) |
| X9252YV24IZ-2.7 (Note) | X9252YV Z G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) (Pb-free) |
| X9252WS24I-2.7 | X9252WS G | 10 | -40 to 85 | 24 Ld SOIC (300 mil) |
| X9252WS24IZ-2.7 (Note) | X9252WS Z G |  | -40 to 85 | 24 Ld SOIC (300 mil) (Pb-Free) |
| X9252WV24I-2.7 | X9252WV G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) |
| X9252WV24IZ-2.7 (Note) | X9252WV Z G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) (Pb-free) |
| X9252US24I-2.7 | X9252US G | 50 | -40 to 85 | 24 Ld SOIC (300 mil) |
| X9252US24IZ-2.7 (Note) | X9252US Z G |  | -40 to 85 | 24 Ld SOIC (300 mil) (Pb-Free) |
| X9252UV24I-2.7 | X9252UV G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) |
| X9252UV24IZ-2.7 (Note) | X9252UV Z G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) (Pb-free) |
| X9252TS24I-2.7 | X9252TS G | 100 | -40 to 85 | 24 Ld SOIC (300 mil) |
| X9252TS24IZ-2.7 (Note) | X9252TS Z G |  | -40 to 85 | 24 Ld SOIC (300 mil) (Pb-Free) |
| X9252TV24I-2.7 | X9252TV G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) |
| X9252TV24IZ-2.7 (Note) | X9252TV Z G |  | -40 to 85 | 24 Ld TSSOP (4.4mm) (Pb-free) |

Intersil Pb-free plus anneal products employ special Pb-free material sets; molding compounds/die attach materials and $100 \%$ matte tin plate termination finish, which are RoHS compliant and compatible with both SnPb and Pb -free soldering operations. Intersil Pb-free products are MSL classified at Pb -free peak reflow temperatures that meet or exceed the Pb -free requirements of IPC/JEDEC J STD-020.

## Functional Diagram



## Pin Descriptions

| SOIC/TSSOP PIN | SYMBOL | BRIEF DESCRIPTION |
| :---: | :---: | :--- |
| 1 | DS0 | DCP select for Up/Down interface. |
| 2 | A0 | Device address for 2-wire bus. |
| 3 | RW3 | Wiper terminal of DCP3. |
| 4 | RH3 | High terminal of DCP3. |

## Pin Descriptions (Continued)

| SOIC/TSSOP PIN | SYMBOL |  |
| :---: | :---: | :--- |
| 5 | RL3 | Low terminal of DCP3. |
| 6 | U/ $\bar{D}$ | Increment/decrement for up/down interface. |
| 7 | VCC | System supply voltage |
| 8 | RL0 | Low terminal of DCP0. |
| 9 | RH0 | High terminal of DCP0. |
| 10 | RW0 | Wiper terminal of DCP0. |
| 11 | A2 | Device address for 2-wire bus. |
| 12 | $\overline{W P}$ | Hardware write protect |
| 13 | SDA | Serial data input/output for 2-wire bus. |
| 14 | A1 | Device address for 2-wire bus. |
| 15 | RL1 | Low terminal of DCP1. |
| 16 | RH1 | High terminal of DCP1. |
| 17 | RW1 | Wiper terminal DCP1. |
| 18 | VSS | System ground |
| 19 | $\overline{C S}$ | Chip select for Up/Down interface. |
| 20 | RW2 | Wiper terminal of DCP2. |
| 21 | RH2 | High terminal of DCP2. |
| 22 | RL2 | Low terminal of DCP2. |
| 23 | SCL | Serial clock for 2-wire bus. |
| 24 | DS1 | DCP select for up/down interface. |

## Pin Descriptions

## Bus Interface Pins

## Serial Data Input/Output (SDA)

The SDA is a bidirectional serial data input/output pin for the 2-wire interface. It receives device address, operation code, wiper register address and data from a 2-wire external master device at the rising edge of the serial clock SCL, and it shifts out data after each falling edge of the serial clock SCL.

SDA requires an external pull-up resistor, since it's an open drain output.

## Serial Clock (SCL)

This input is the serial clock of the 2-wire and Up/Down interface.

## Device Address (A2-A0)

The Address inputs are used to set the least significant 3 bits of the 8 -bit 2 -wire interface slave address. A match in the slave address serial data stream must be made with the Address input pins in order to initiate communication with the X9252. A maximum of 8 devices may occupy the 2 -wire serial bus.

## Chip Select ( $\overline{\mathrm{CS}}$ )

When the $\overline{\mathrm{CS}}$ pin is low, increment or decrement operations are possible using the $S C L$ and $U / \bar{D}$ pins. The 2-wire
interface is disabled at this time. When $\overline{\mathrm{CS}}$ is high, the 2-wire interface is enabled.

## Up or Down Control (U/D)

The U/ $\overline{\mathrm{D}}$ input pin is held HIGH during increment operations and held LOW during decrement operations.

## DCP Select (DS1-DS0)

The DS1-DS0 select one of the four DCPs for an Up/Down interface operation.

## Hardware Write Protect Input ( $\overline{\mathbf{W P}}$ )

When the $\overline{W P}$ pin is set low, "write" operations to non volatile DCP Data Registers are disabled. This includes both 2-wire interface non-volatile "Write", and Up/Down interface "Store" operations.

## DCP Pins

$\mathbf{R}_{\mathrm{H} 0}, \mathbf{R}_{\mathrm{L} 0}, \mathbf{R}_{\mathrm{H} 1}, \mathbf{R}_{\mathrm{L} 1}, \mathbf{R}_{\mathrm{H} 2}, \mathbf{R}_{\mathrm{L} 2}, \mathbf{R}_{\mathrm{H} 3}$, and $\mathbf{R}_{\mathrm{L} 3}$
These pins are equivalent to the terminal connections on mechanical potentiometers. Since there are 4 DCPs, there is one set of $R_{H}$ and $R_{L}$ for each DCP.

## $\mathrm{R}_{\mathrm{W} 0}, \mathrm{R}_{\mathrm{W} 1}, \mathrm{R}_{\mathrm{W} 2}$, and $\mathrm{R}_{\mathrm{W} 3}$

The wiper pins are equivalent to the wiper terminal of mechanical potentiometers. Since there are four DCPs, there are $4 \mathrm{R}_{\mathrm{W}}$ pins.

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Junction Temperature under bias. | . $-65^{\circ} \mathrm{C}$ to $+135^{\circ} \mathrm{C}$ |
| Storage temperature | .$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage at any digital interface pin with respect to $\mathrm{V}_{\mathrm{SS}}$. | -1V to +7V |
| $\mathrm{V}_{\mathrm{CC}}$ | -1 V to +7 V |
| Voltage at any DCP pin with respect to $\mathrm{V}_{\mathrm{SS}}$. | -1V to $\mathrm{V}_{\mathrm{CC}}$ |
| Lead temperature (soldering, 10s). | $300^{\circ} \mathrm{C}$ |
| IW (10s) | $\pm 6 \mathrm{~mA}$ |

## Recommended Operating Conditions

Commercial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ Industrial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ )(Note 4) Limits . . . . . . . . . . . . . . . 2.7V to 5.5 V

CAUTION: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only; functional operation of the device (at these or any other conditions above those listed in the operational sections of this specification) is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Analog Specifications Over recommended operating conditions unless otherwise stated.


DC Electrical Specifications Over the recommended operating conditions unless otherwise specified.

| SYMBOL | PARAMETER | TEST CONDITIONS | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICC1 | $\mathrm{V}_{\mathrm{CC}}$ supply current (Volatile write/read) | $\mathrm{f}_{\mathrm{SCL}}=400 \mathrm{kHz} ; \mathrm{SDA}=$ Open; (for 2-Wire, Active, Read and Volatile Write States only) |  | 3 | mA |
| ${ }^{\text {I CC2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ supply current (active) | $\begin{aligned} & \mathrm{f} S \mathrm{SL}=200 \mathrm{kHz} ; \\ & \text { (for U/D interface, increment, decrement) } \end{aligned}$ |  | 3 | mA |
| ${ }^{\text {c CC3 }}$ | $\mathrm{V}_{\mathrm{CC}}$ supply current (nonvolatile write) | fSCL $=400 \mathrm{kHz}$; SDA $=$ Open; <br> (for 2-Wire, Active, Nonvolatile Write State only) |  | 5 | mA |
| $I_{\text {SB }}$ | $\mathrm{V}_{\mathrm{CC}}$ current (standby) | $\mathrm{V}_{\mathrm{CC}}=+5.5 \mathrm{~V} ; \mathrm{V}_{I \mathrm{~N}}=\mathrm{V}_{\mathrm{SS}} \text { or } \mathrm{V}_{\mathrm{CC}} ; \mathrm{SDA}=\mathrm{V}_{\mathrm{CC}}$ <br> (for 2-Wire, Standby State only) |  | 100 | $\mu \mathrm{A}$ |

DC Electrical Specifications Over the recommended operating conditions unless otherwise specified. (Continued)

| SYMBOL | PARAMETER | TEST CONDITIONS | MIN | MAX | UNITS |
| :---: | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{L}}$ | Leakage current, bus interface pins | Voltage at pin from $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{CC}}$ | -10 | 10 | $\mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input HIGH voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ | $\mathrm{~V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input LOW voltage |  | -1 | $\mathrm{~V}_{\mathrm{CC}} \times 0.3$ | V |
| $\mathrm{~V}_{\mathrm{OL}}$ | SDA pin output LOW voltage | $\mathrm{IOL}_{\mathrm{O}}=3 \mathrm{~mA}$ |  | 0.4 | V |

## Endurance and Data Retention

| PARAMETER | MIN | UNITS |
| :---: | :---: | :---: |
| Minimum endurance | 100,000 | Data changes per bit |
| Data retention | 100 | Years |

## Capacitance

| Symbol | Test | Test Conditions | Max. | Units |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN/OUT }}$ (Note 5) | Input / Output capacitance (SDA) | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ (Note 5) | Input capacitance (SCL, $\overline{\mathrm{WP}}, \mathrm{DS} 0, \mathrm{DS} 1, \overline{\mathrm{CS}}, \mathrm{U} / \overline{\mathrm{D}}, \mathrm{A} 2, \mathrm{~A} 1$ and <br> $\mathrm{A0})$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 6 | pF |

## Power-Up Timing

| SYMBOL | PARAMETER | MAX | UNITS |
| :---: | :--- | :---: | :---: |
| $\mathrm{t}_{\mathrm{D}}($ Notes 5,9$)$ | Power Up Delay from $\mathrm{V}_{\mathrm{CC}}$ power up $\left(\mathrm{V}_{\mathrm{CC}}\right.$ above 2.7V) to wiper position recall <br> completed, and communication interfaces ready for operation. | 2 | ms |

## A.C. Test Conditions

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input rise and fall times | 10 ns |
| Input and output timing threshold level | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| External load at pin SDA | $2.3 \mathrm{k} \Omega$ to $\mathrm{V}_{\mathrm{CC}}$ and 100 pF to $\mathrm{V}_{\mathrm{SS}}$ |

2-Wire Interface timing (s)

| SYMBOL | PARAMETER | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {SCL }}$ | Clock Frequency |  | 400 | kHz |
| $\mathrm{t}_{\mathrm{HIGH}}$ | Clock High Time | 600 |  | ns |
| tLOW | Clock Low Time | 1300 |  | ns |
| tSU:STA | Start Condition Setup Time | 600 |  | ns |
| $t_{\text {HD: }}$ STA | Start Condition Hold Time | 600 |  | ns |
| tsu:STO | Stop Condition Setup Time | 600 |  | ns |
| tsu:DAT | SDA Data Input Setup Time | 100 |  | ns |
| $\mathrm{t}_{\mathrm{HD}: \text { DAT }}$ | SDA Data Input Hold Time | 30 |  | ns |
| $\mathrm{t}_{\mathrm{R}}$ (Note 5) | SCL and SDA Rise Time |  | 300 | ns |
| $\mathrm{t}_{\mathrm{F}}$ (Note 5) | SCL and SDA Fall Time |  | 300 | ns |
| $\mathrm{t}_{\text {AA }}$ (Note 5) | SCL Low to SDA Data Output Valid Time |  | 0.9 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ H | SDA Data Output Hold Time | 0 |  | ns |
| $\mathrm{t}_{\mathrm{IN}}$ (Note 5) | Pulse Width Suppression Time at SCL and SDA inputs |  | 50 | ns |

2-Wire Interface timing (s) (Continued)

| SYMBOL | PARAMETER | MIN | MAX | UNITS |
| :--- | :--- | :---: | :---: | :---: |
| tBUF (Note 5) | Bus Free Time (Prior to Any Transmission) | 1200 |  | ns |
| tsu:WPA <br> (Note 5) | A0, A1, A2 and $\overline{\text { WP }}$ Setup Time | 600 |  | ns |
| thD:WPA <br> (Note 5) | A0, A1, A2 and $\overline{\text { WP }}$ Hold Time | 600 | ns |  |

## SDA vs SCL Timing



## $\overline{W P}, A 0, A 1$, and A2 Pin Timing



## Increment/Decrement Timing

| SYMBOL | PARAMETER | MIN | TYP (Note 4) | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }} \mathrm{Cl}$ | $\overline{\mathrm{CS}}$ to SCL Setup | 600 |  |  | ns |
| $\mathrm{t}_{\text {ID }}$ (Note 5) | SCL HIGH to U/D, DS0 or DS1 change | 600 |  |  | ns |
| $\mathrm{t}_{\mathrm{DI}}$ (Note 5) | U/D, DS0 or DS1 to SCL setup | 600 |  |  | ns |
| $t_{\text {IL }}$ | SCL LOW period | 2.5 |  |  | $\mu \mathrm{s}$ |
| tIH | SCL HIGH period | 2.5 |  |  | $\mu \mathrm{s}$ |
| $t_{1 C}$ | SCL inactive to $\overline{\mathrm{CS}}$ inactive (Nonvolatile Store Setup Time) | 1 |  |  | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ CPHS | $\overline{\mathrm{CS}}$ deselect time (STORE) | 10 |  |  | ms |
| $t_{\text {CPHNS }}$ <br> (Note 5) | $\overline{\mathrm{CS}}$ deselect time (NO STORE) | 1 |  |  | $\mu \mathrm{s}$ |
| tIW (Note 5) | SCL to RW change |  | 100 | 500 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CYC}}$ | SCL cycle time | 5 |  |  | $\mu \mathrm{s}$ |
| $t_{R}, t_{F}($ Note 5) | SCL input rise and fall time |  |  | 500 | $\mu \mathrm{s}$ |

## Increment/Decrement Timing



## High-Voltage Write Cycle Timing

| SYMBOL | PARAMETER | TYP | MAX |
| :---: | :--- | :---: | :---: |
| $t_{\text {WC }}$ <br> (Notes 5, 8) | Non-volatile write cycle time | 5 | 10 |

## XDCP Timing

| SYMBOL | PARAMETER | MIN | MAX | UNITS |
| :---: | :--- | :---: | :---: | :---: |
| tWRL (Note 5) | SCL rising edge to wiper code changed, wiper response time after instruction <br> issued (all load instructions) | 5 | 20 | $\mu s$ |

## NOTES:

1. Absolute linearity is utilized to determine actual wiper voltage versus expected voltage $=\left[\mathrm{V}\left(\mathrm{R}_{\mathrm{W}(\mathrm{n})}\right.\right.$ (actual) $)-\mathrm{V}\left(\mathrm{R}_{\mathrm{W}(\mathrm{n})}\right)($ expected $\left.)\right] / \mathrm{Ml}$ $\mathrm{V}\left(\mathrm{R}_{\mathrm{W}(\mathrm{n})(\text { expected })}\right)=\mathrm{n}\left(\mathrm{V}\left(\mathrm{R}_{\mathrm{H}}\right)-\mathrm{V}\left(\mathrm{R}_{\mathrm{L}}\right)\right) / 255+\mathrm{V}\left(\mathrm{R}_{\mathrm{L}}\right)$, with n from 0 to 255 .
2. Relative linearity is a measure of the error in step size between taps $=\left[V\left(R_{W}(n+1)\right)-\left(V\left(R_{W}(n)\right)+M I\right)\right] / M I$, with $n$ from 0 to 254
3. $1 \mathrm{MI}=$ Minimum Increment $=\left[\mathrm{V}\left(\mathrm{R}_{\mathrm{H}}\right)-\mathrm{V}\left(\mathrm{R}_{\mathrm{L}}\right)\right] / 255$.
4. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
5. This parameter is not $100 \%$ tested.
6. Ratiometric temperature coefficient $=\left(V\left(R_{W}\right)_{T 1(n)}-\mathrm{V}\left(R_{W}\right) T 2(n) /\left[V\left(R_{W}\right)_{T 1(n)}(T 1-T 2)\right] \times 10^{6}\right.$, with $T 1$ \& $T 2$ being 2 temperatures, and $n$ from 0 to 255.
7. Measured with wiper at tap position $255, R_{L}$ grounded, using test circuit.
8. $\mathrm{t}_{\mathrm{WC}}$ is the minimum cycle time to be allowed for any nonvolatile write by the user, unless Acknowledge Polling is used. It is the time from a valid STOP condition at the end of a write sequence of a 2 -wire interface write operation, or from the rising edge of $\overline{C S}$ of a valid "Store" operation of the Up/Down interface, to the end of the self-timed internal nonvolatile write cycle.
9. The recommended power up sequence is to apply $\mathrm{V}_{C C} / V_{S S}$ first, then the potentiometer voltages. During power up, the data sheet parameters for the DCP do not fully apply until $t_{D}$ after $V_{C C}$ reaches its final value. In order to prevent unwanted tap position changes, or an inadvertant store, bring the $\overline{\mathrm{CS}}$ pin high before or concurrently with the $\mathrm{V}_{\mathrm{CC}}$ pin on power up.

## Test Circuit



## Principles of Operation

The X9252 is an integrated circuit incorporating four resistor arrays, their associated registers and counters, and the serial interface logic providing direct communication between the host and the digitally controlled potentiometers. This section provides detail description of the following:

- Resistor Array
- Up/Down Interface
- 2-wire Interface


## Resistor Array Description

The X9252 is comprised of four resistor arrays. Each array contains 255 discrete resistive segments that are connected in series. The physical ends of each array are equivalent to the fixed terminals of a mechanical potentiometer ( $\mathrm{R}_{\mathrm{Hi}}$ and $\mathrm{R}_{\mathrm{Li}}$ inputs) (See Figure 1.)

At both ends of each array and between each resistor segment is a switch connected to the wiper $\left(R_{W i}\right)$ pin.

## Equivalent Circuit



Within each individual array only one switch may be turned on at a time.

These switches are controlled by a Wiper Counter Register (WCR). The 8-bits of the WCR (WCR[7:0]) are decoded to select and enable one of 256 switches (see Table 1). Note that each wiper has a dedicated WCR. When all bits of a WCR are zeroes, the switch closest to the corresponding $\mathrm{R}_{\mathrm{L}}$ pin is selected. When all bits of a WCR are ones, the switch closest to the corresponding $\mathrm{R}_{\mathrm{H}}$ pin is selected.

The WCR is volatile and may be written directly. There are four non-volatile Data Registers (DR) associated with each WCR. Each DR can be loaded into WCR. All DRs and WCRs can be read or written.

## Power Up and Down Requirements

During power up, $\overline{\mathrm{CS}}$ must be high, to avoid inadvertant "store" operations. At power up, the contents of Data Registers DR00, DR10, DR20, and DR30, are loaded into the corresponding wiper counter register.


FIGURE 1. DETAILED BLOCK DIAGRAM OF ONE DCP

## Up/Down Interface Operation

The SCL, U/ $\bar{D}, \overline{C S}, D S 0$ and DS1 inputs control the movement of the wiper along the resistor array. With $\overline{\mathrm{CS}}$ set LOW the device is selected and enabled to respond to the U/D and SCL inputs. HIGH to LOW transitions on SCL will increment or decrement (depending on the state of the U/D input) a wiper counter register selected by DS0 and DS1. The output of this counter is decoded to select one of 256 wiper positions along the resistor array.

The value of the counter is stored in nonvolatile Data Registers DRi0 whenever $\overline{\mathrm{CS}}$ transitions HIGH while the SCL and $\overline{W P}$ inputs are HIGH. "i" indicates the DCP number selected with pins DS1 and DS0. During a "Store" operation bits DRSel1 and DRSel0 in the Status Register must be both " 0 ", which is their power up default value. Other combinations are reserved and must not be used.

The system may select the X9252, move the wiper, and deselect the device without having to store the latest wiper position in nonvolatile memory. After the wiper movement is performed as described above and once the new position is reached, the system must keep SCL LOW while taking $\overline{\mathrm{CS}}$ HIGH. The new wiper position will be maintained until changed by the system or until a power-down/up cycle recalled the previously stored data.

This procedure allows the system to always power-up to a preset value stored in nonvolatile memory; then during system operation minor adjustments could be made. The adjustments might be based on user preference, system parameter changes due to temperate drift, etc.
The state of U/D may be changed while $\overline{C S}$ remains LOW. This allows the host system to enable the device and then move the wiper up and down until the proper trim is attained. The 2-wire interface is disabled while $\overline{\mathrm{CS}}$ remains LOW.

TABLE 1. DCP SELECTION FOR UPIDOWN CONTROL

| DS1 | DS0 | SELECTED DCP |
| :---: | :---: | :---: |
| 0 | 0 | DCP0 |
| 0 | 1 | DCP1 |
| 1 | 0 | DCP2 |
| 1 | 1 | DCP3 |

Mode Selection for Up/Down Control

| CS | SCL | U/D | MODE |
| :---: | :---: | :---: | :---: |
| L | 1 | H | Wiper Up |
| L | $7$ | L | Wiper Down |
| $\checkmark$ | H | X | Store Wiper Position to nonvolatile memory if $\overline{\mathrm{WP}}$ pin is high. No store, return to standby, if $\overline{\mathrm{WP}}$ pin is low. |
| H | X | X | Standby |
| $\checkmark$ | L | X | No Store, Return to Standby |
| $\square$ | L | H | Wiper Up (not recommended) |
| $\square$ | L | L | Wiper Down (not recommended) |

## 2-Wire Serial Interface

## Protocol Overview

The device supports a bidirectional bus oriented protocol. The protocol defines any device that sends data onto the bus as a transmitter, and the receiving device as the receiver. The device controlling the transfer is called the master and the device being controlled is called the slave. The master always initiates data transfers, and provides the clock for both transmit and receive operations. The X9252 operates as a slave in all applications.

All 2-wire interface operations must begin with a START, followed by a Slave Address byte. The Slave Address selects the X9252, and specifies if a Read or Write operation is to be performed.

All Communication over the 2-wire interface is conducted by sending the MSB of each byte of data first.

## Serial Clock and Data

Data states on the SDA line can change only while SCL is LOW. SDA state changes while SCL is HIGH are reserved for indicating START and STOP conditions (See Figure 2). On power up of the X9252, the SDA pin is in the input mode.

## Serial Start Condition

All commands are preceded by the START condition, which is a HIGH to LOW transition of SDA while SCL is HIGH. The device continuously monitors the SDA and SCL lines for the START condition and does not respond to any command until this condition has been met (See Figure 2).

## Serial Stop Condition

All communications must be terminated by a STOP condition, which is a LOW to HIGH transition of SDA while SCL is HIGH. The STOP condition is also used to place the device into the Standby power mode after a read sequence. A STOP condition can only be issued after the transmitting device has released the bus (See Figure 2).


FIGURE 2. VALID DATA CHANGES, START, AND STOP CONDITIONS


FIGURE 3. ACKNOWLEDGE RESPONSE FROM RECEIVER

## Serial Acknowledge

An ACK (Acknowledge), is a software convention used to indicate a successful data transfer. The transmitting device, either master or slave, releases the bus after transmitting eight bits. During the ninth clock cycle, the receiver pulls the SDA line LOW to acknowledge the reception of the eight bits of data (See Figure 3).

The device responds with an ACK after recognition of a START condition followed by a valid Slave Address byte. A valid Slave Address byte must contain the Device Type Identifier 0101, and the Device Address bits matching the logic state of pins A2, A1, and A0 (See Figure 4).

If a write operation is selected, the device responds with an ACK after the receipt of each subsequent eight-bit word.

In the read mode, the device transmits eight bits of data, releases the SDA line, and then monitors the line for an ACK. The device continues transmitting data if an ACK is detected. The device terminates further data transmissions if an ACK is not detected. The master must then issue a STOP condition to place the device into a known state.

## Slave Address Byte

Following a START condition, the master must output a Slave Address Byte (Refer to figure 4.). This byte includes three parts:

- The four MSBs (SA7-SA4) are the Device Type Identifier, which must always be set to 0101 in order to select the X9252.
- The next three bits (SA3-SA1) are the Device Address bits (AS2-ASO). To access any part of the X9252's memory, the value of bits AS2, AS1, and AS0 must correspond to the logic levels at pins A2, A1, and A0 respectively.
- The LSB (SAO) is the R/W bit. This bit defines the operation to be performed on the device being addressed. When the $R / \bar{W}$ bit is " 1 ", then a Read operation is selected. A " 0 " selects a Write operation.


| SLAVE ADDRESS <br> BIT(S) | DESCRIPTION |
| :---: | :--- |
| SA7-SA4 | Device Type Identifier |
| SA3-SA1 | Device Address |
| SA0 | Read or Write Operation Select |

FIGURE 4. SLAVE ADDRESS (SA) FORMAT

## Nonvolatile Write Acknowledge Polling

After a nonvolatile write command sequence is correctly issued (including the final STOP condition), the X9252 initiates an internal high voltage write cycle. This cycle typically requires 5 ms . During this time, any Read or Write command is ignored by the X9252. Write Acknowledge Polling is used to determine whether a high voltage write cycle is completed.

During acknowledge polling, the master first issues a START condition followed by a Slave Address Byte. The Slave Address Byte contains the X9252's Device Type Identifier and Device Address. The LSB of the Slave Address (R/W) can be set to either 1 or 0 in this case. If the device is busy within the high voltage cycle, then no ACK is returned. If the high voltage cycle is completed, an ACK is returned and the master can then proceed with a new Read or Write operation. (Refer to figure 5.)


FIGURE 5. ACKNOWLEDGE POLLING SEQUENCE

## 2-Wire Serial Interface Operation

## X9252 Digital Potentiometer Register Organization

Refer to the Functional Diagram on page 2. There are four Digitally Controlled Potentiometers, referred to as DCPi, $\mathrm{i}=0,1,2,3$. Each potentiometer has one volatile Wiper Control Register (WCR) with the corresponding number, WCRi, $i=0,1,2,3$. Each potentiometer also has four nonvolatile registers to store wiper position or general data, these are numbered DRi0, DRi1, DRi2 and DRi3, $\mathrm{i}=0,1,2,3$.

The registers are organized in five pages of four, with one page consisting of the WCRi $(i=0-3)$, a second page containing the DRi0 ( $\mathrm{i}=0-3$ ), a third page containing the DRi1, and so forth. These pages can be written to four bytes at time. In this manner all four potentiometer WCRs can be updated in a single serial write (see "Page Write Operation"), as well as all four registers of a given page in the DR array.

The unique feature of the X9252 device is that writing or reading to a Data Register of a given DCP automatically updates/moves the WCR of that DCP with the content of the DR. In this manner data can be moved from a particular DCP register to that DCP's WCR just by performing a 2-wire read operation. Simultaneously, that data byte can be utilized by the host.

## Status Register Organization

The Status Register (SR) is used in read and write operations to select the appropriate DCP register. Before any DCP register can be accessed, the SR must be set to the correct value. It is accessed by setting the Address Byte to 07h (See Table 3). Do this by Writing the Slave Address followed by a Byte Address of 07h. The SR is volatile and defaults to 00 h on power up. It is an 8-bit register containing three control bits in the 3 LSBs as follows:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | DRSel1 | DRSel0 | NVEnable |  |

Bits DRSel1 and DRSel0 determine which Data Register of a DCP is selected for a given operation. NVEnable is used to select the volatile WCR if " 0 ", and one of the nonvolatile DCP registers if " 1 ". Table 2 shows this register organization. "Store" operations using the Up/Down interface require that bits DRSel1 and DRSel0 are set to " 0 ".

TABLE 2. REGISTER NUMBERING

| STATUS REG (Note 1) (Addr: 07H) |  |  |  | REGISTERED SELECTED (Note 2) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RESERVED BITS 7-3 | DRSel1 bit 2 | DRSel0 bit 1 | NVEnable bit 0 | DCPO | DCP1 | DCP2 | DCP3 |
|  |  |  |  | (Addr: 00h) | (Addr: 01h) | (Addr: 02h) | (Addr: 03h) |
| Reserved | X | X | 0 | WCR0 | WCR1 | WCR2 | WCR3 |
|  | 0 | 0 | 1 | DR00 | DR10 | DR20 | DR30 |
|  | 0 | 1 | 1 | DR01 | DR11 | DR21 | DR31 |
|  | 1 | 0 | 1 | DR02 | DR12 | DR22 | DR32 |
|  | 1 | 1 | 1 | DR03 | DR13 | DR23 | DR33 |

To read or write the contents of a single Data Register or Wiper Register:

1. Load the status register (using a write command) to select the row (See Figure 6)

Writing a 1,3 , 5 , or 7 to the Status Register specifies that the subsequent read or write command will access a Data Register. This Status Register operation also initiates a transfer of the contents of the selected data register to its associated WCR for all DCPs. So, for example, writing '03h' to the status register causes the value in DR01 to move to WCR0, DR11 to move to WCR1, DR21 to move to WCR2, and DR31 to move to WCR3.

Writing a 0 to bit ' 0 ' of the Status Register specifies that the subsequent read or write command will access a Wiper Counter Register. Each WCR can be written to individually, without affecting the contents of any other.
2. Access the desired DR or WCR using a new write or read command (see Figure 7 for write and Figure 9 for read.) Specify the desired column (DCP number) by sending the DCP address as part of this read or write command.


FIGURE 6. STATUS REGISTER WRITE (USES STANDARD BYTE WRITE SEQUENCE TO SET UP ACCESS TO A DATA REGISTER)

## DCP Addressing for 2-Wire Interface

Once the register number has been selected by a 2-wire instruction, then the DCP number is determined by the Address Byte of the following instruction. Note again that this enables a complete page write of the DRs of all four potentiometers at once. The register addresses accessible in the X9252 include:

TABLE 3. 2-WIRE INTERFACE ADDRESS BYTE

| ADDRESS (HEX) | CONTENTS |
| :---: | :---: |
| 0 | DCP 0 |
| 1 | DCP 1 |
| 2 | DCP 2 |
| 3 | DCP 3 |
| 4 | Not Used |
| 5 | Not Used |
| 6 | Not Used |
| 7 | Status Register |

All other address bits in the Address Byte must be set to "0" during 2-wire write operations and their value should be ignored when read.

## Byte Write Operation

For any Byte Write operation, the X9252 requires the Slave Address byte, an Address Byte, and a Data Byte (See Figure 7). After each of them, the X9252 responds with an ACK. The master then terminates the transfer by generating a STOP condition. At this time, if the write operation is to a volatile register (WCR, or SR), the X9252 is ready for the next read or write operation. If the write operation is to a nonvolatile register (DR), and the $\overline{\mathrm{WP}}$ pin is high, the X9252 begins the internal write cycle to the nonvolatile memory. During the internal nonvolatile write cycle, the X9252 does
not respond to any requests from the master. The SDA output is at high impedance.

The SR bits and $\overline{\mathrm{WP}}$ pin determine the register being accessed through the 2-wire interface (See Table 2).

As noted before, any write operation to a Data Register (DR), also transfers the contents of all the data registers in that row to their corresponding WCR.

For example, to write 3Ahex to the Data Register 1 of DCP2 the following sequence is required:

START

| Slave Address <br> ACK | 01010000 | (Hardware Address = 000, <br> and a Write command) |
| :--- | :--- | :--- |
| Address Byte <br> ACK | 00000111 | (Indicates Status Register <br> address) |
| Data Byte <br> ACK <br> note: at this ACK, the WCRs are all updated with their respective DR. <br> STOP <br> NVEnable selected) |  |  |
| START <br> Slave Address <br> ACK | 00000011 | (Hate Regist 101000 |
| Address Byte <br> ACK <br> Data Byte | 00000010 | (Hardware address = 000, <br> Write command) <br> (Access DCP2) |
| ACK <br> STOP | 00111010 | (Write Data Byte 3Ah) |

During the sequence of this example, $\overline{\mathrm{WP}}$ pin must be high, and A0, A1, and A2 pins must be low. When completed, the DR21 register and the WCR2 will be set to 3Ah and the other Data Register in Row 1 will transfer their other contents to the respective WCR's.


FIGURE 7. BYTE WRITE SEQUENCE

## Page Write Operation

As stated previously, the memory is organized as a single Status Register (SR), and four pages of four registers each. Each page contains one Data Register for each DCP. The order of the bytes within a page is DR0i, followed by DR1i, followed by DR2i, and then DR3i, with $i$ being the Data Register number ( $0,1,2$, or 3 ). Normally a page write operation will be used to efficiently update all four data registers and WCR in a single write command, starting at DCP0 and finishing with DCP3.

In order to perform a Page Write operation to the memory array, the NVEnable bit in the SR must first be set to " 1 ".

A Page Write operation is initiated in the same manner as the byte write operation; but instead of terminating the write cycle after the first data byte is transferred, the master can transmit up to 4 bytes (See Figure 8). After the receipt of each byte, the X9252 responds with an ACK, and the internal DCP address counter is incremented by one. The page address remains constant. When the counter reaches
the end of the page (DR3i, 03hex), it "rolls over" and goes back to the first byte of the same page (DR0i, 00hex).

For example, if the master writes 3 bytes to a page starting at location DR22, the first 2 bytes are written to locations DR22 and DR32, while the last byte is written to locations DR02. Afterwards, the DCP counter would point to location DR12. If the master supplies more than 4 bytes of data, then new data overwrites the previous data, one byte at a time.

The master terminates the loading of Data Bytes by issuing a STOP condition, which initiates the nonvolatile write cycle. As with the Byte Write operation, all inputs are disabled until completion of the internal write cycle. If the $\overline{W P}$ pin is low, the nonvolatile write cycle doesn't start and the bytes are discarded.

Notice that the Data Bytes are also written to the WCR of the corresponding DCPs, therefore in the above example, WCR2, WCR3, and WCR0 are also written and WCR1 is updated with the contents of DR12.


FIGURE 8. PAGE WRITE OPERATION

## Move/Read Operation

The Move/Read operation simultaneously reads the contents of a Data Register (DR) and moves the contents into the corresponding DCP's WCR and the WCRs of all DCPs are updated with the content of their corresponding DR. Move/Read operation consists of a one byte, or three byte instruction followed by one or more Data Bytes (See Figure 9). To read an arbitrary byte, the master initiates the operation issuing the following sequence: a START, the Slave Address byte with the R/W bit set to " 0 ", an Address Byte, a second START, and a second Slave Address byte with the $R / \bar{W}$ bit set to " 1 ". After each of the three bytes, the X9252 responds with an ACK. Then the X9252 transmits

Data Bytes as long as the master responds with an ACK during the SCL cycle following the eight bit of each byte. The master terminates the Move/Read operation (issuing a STOP condition) following the last bit of the last Data Byte.

The first byte being read is determined by the current DCP address and by the Status Register bits, according to Table 2. If more than one byte is read, the DCP address is incremented by one after each byte, in the same way as during a Page Write operation. After reaching DCP3, the DCP address "rolls over" to DCPO.

On power up, the Address pointer is set to the Data Register 0 of DCPO.


FIGURE 9. MOVE/READ SEQUENCE

## Applications Information

## Basic Configurations of Electronic Potentiometers



Three terminal
Potentiometer;
Variable voltage divider


Two terminal Variable
Resistor; Variable current

## Application Circuits

NONINVERTING AMPLIFIER

$V_{O}=\left(1+R_{2} / R_{1}\right) V_{S}$

## OFFSET VOLTAGE ADJUSTMENT




COMPARATOR WITH HYSTERISIS

$V_{U L}=\left\{R_{1} /\left(R_{1}+R_{2}\right)\right\} V_{O}$ (max)
$R L_{L}=\left\{R_{1} /\left(R_{1}+R_{2}\right)\right\} V_{O}(\min )$

## Application Circuits (Continued)



INVERTING AMPLIFIER

$V_{\mathrm{O}}=G V_{S}$
$G=-R_{2} / R_{1}$

FILTER


$$
G_{O}=1+R_{2} / R_{1}
$$

$$
f c=1 /(2 \pi R C)
$$

## EQUIVALENT L-R CIRCUIT



$$
Z_{I N}=R_{2}+s R_{2}\left(R_{1}+R_{3}\right) C_{1}=R_{2}+s L e q
$$

$$
\left(R_{1}+R_{3}\right) \gg R_{2}
$$

FUNCTION GENERATOR

frequency $\propto R_{1}, R_{2}, C$ amplitude $\propto R_{A}, R_{B}$

## Application Circuits (Continued)




NOTE: ALL DIMENSIONS IN INCHES (IN PARENTHESES IN MILLIMETERS)

## Packaging Information



NOTE: ALL DIMENSIONS IN INCHES (IN PARENTHESES IN MILLIMETERS)

All Intersil U.S. products are manufactured, assembled and tested utilizing ISO9000 quality systems. Intersil Corporation's quality certifications can be viewed at www.intersil.com/design/quality

Intersil products are sold by description only. Intersil Corporation reserves the right to make changes in circuit design, software and/or specifications at any time without notice. Accordingly, the reader is cautioned to verify that data sheets are current before placing orders. Information furnished by Intersil is believed to be accurate and reliable. However, no responsibility is assumed by Intersil or its subsidiaries for its use; nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Intersil or its subsidiaries.

For information regarding Intersil Corporation and its products, see www.intersil.com

